-
Notifications
You must be signed in to change notification settings - Fork 40.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for detecting AWS Advanced JDBC Wrapper to DatabaseDriver #43812
Conversation
This commit adds entry for AWS Advanced JDBC Wrapper to `DatabaseDriver` enum. See spring-projectsgh-31995 Signed-off-by: Vedran Pavic <[email protected]>
|
||
@Override | ||
protected Collection<String> getUrlPrefixes() { | ||
return List.of("aws-wrapper"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've used List#of
as it seems to be the simplest option, but note that implementations of #getUrlPrefixes
in this enum are quite inconsistent - there are usages of Arrays#asList
and Collections#singleton
.
Perhaps this could be aligned in a separate issue to use List#of
consistently (first-timers-only
candidate?).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
They seem consistent to me, using Collections#singleton
when there's a single prefix and Arrays#asList
when there a multiple prefixes. I'll polish to use Collections#singleton
when merging.
Thanks, @vpavic. In isolation, I wonder how useful this will be. Looking at how |
Thanks for the feedback. Motivation here is to simplify usage of AWS Advanced JDBC Wrapper by not having to specify I understand your concerns, and have refreshed my memory a bit on support for vendor-specific Flyway migrations (yes, I contributed that quite some while ago 🙂) and I believe your comment aims at this usage of Lines 391 to 392 in 269c761
This indeed doesn't play nice with wrapper drivers but such use cases could be updated to rely on database product name instead. I can contribute that if you agree with that direction. I can see that such approach is already used in Lines 139 to 141 in 269c761
In any case, I think these concerns are not new since Testcontainers JDBC driver also is of similar nature as it wraps the underlying JDBC driver and requires inserting its prefix into JDBC URL. |
Thanks, @vpavic. After experimenting a bit with the Testcontainers JDBC driver, I learned that it isn't affected as it delegates the metadata request to the underlying driver. Having learned that, I tried the same with the AWS wrapper and it behaves the same way so the problem that I had anticipated does not occur. To summarise:
|
This commit adds an entry for the AWS Advanced JDBC Wrapper to the DatabaseDriver enum. This allows the driver class name to be auto-detected from jdbc:aws-wrapper:… URLs. See gh-43812 Signed-off-by: Vedran Pavic <[email protected]>
Thanks very much, @vpavic. |
This commit adds entry for AWS Advanced JDBC Wrapper to
DatabaseDriver
enum.See gh-31995